home *** CD-ROM | disk | FTP | other *** search
/ MacHack 1996 / MacHack 1996.toast / Hacks / Hacks ’87 / Source ƒ.sit / Source ƒ / XLISP ƒ / XLISP 1.7 C SRCS / xlbfun.c < prev    next >
MacBinary  |  1986-07-08  |  9.6 KB  |  [TEXT/□□□□]

open in: MacOS 8.1     |     Win98     |     DOS

browse contents    |     view JSON data     |     view as text


This file was processed as: MacBinary (archive/macBinary).

ConfidenceProgramDetectionMatch TypeSupport
66% dexvert Compact Compressed (Unix) (archive/compact) ext Supported
10% dexvert MacBinary (archive/macBinary) fallback Supported
1% dexvert Text File (text/txt) fallback Supported
100% file MacBinary II, inited, Mon Jul 7 21:56:01 1986, modified Mon Jul 7 21:56:01 1986, type ASCII, 9284 bytes "xlbfun.c" , at 0x24c4 348 bytes resource default (weak)
99% file data default
74% TrID Macintosh plain text (MacBinary) default
25% TrID MacBinary 2 default (weak)
100% siegfried fmt/1762 MacBinary (II) default
100% lsar MacBinary default


id metadata
keyvalue
macFileType[TEXT]
macFileCreator[□□□□]



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 00 08 78 6c 62 66 75 6e | 2e 63 00 00 00 00 00 00 |..xlbfun|.c......|
|00000010| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 54 45 58 54 00 00 00 | 00 01 00 00 00 00 00 00 |.TEXT...|........|
|00000050| 00 00 00 00 00 24 44 00 | 00 01 5c 9b 36 23 b1 9b |.....$D.|..\.6#..|
|00000060| 36 23 b1 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |6#......|........|
|00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 9c 1e 00 00 |........|........|
|00000080| 2f 2a 20 78 6c 62 66 75 | 6e 2e 63 20 2d 20 78 6c |/* xlbfu|n.c - xl|
|00000090| 69 73 70 20 62 61 73 69 | 63 20 62 75 69 6c 74 2d |isp basi|c built-|
|000000a0| 69 6e 20 66 75 6e 63 74 | 69 6f 6e 73 20 2a 2f 0d |in funct|ions */.|
|000000b0| 2f 2a 09 43 6f 70 79 72 | 69 67 68 74 20 28 63 29 |/*.Copyr|ight (c)|
|000000c0| 20 31 39 38 35 2c 20 62 | 79 20 44 61 76 69 64 20 | 1985, b|y David |
|000000d0| 4d 69 63 68 61 65 6c 20 | 42 65 74 7a 0d 09 41 6c |Michael |Betz..Al|
|000000e0| 6c 20 52 69 67 68 74 73 | 20 52 65 73 65 72 76 65 |l Rights| Reserve|
|000000f0| 64 0d 09 50 65 72 6d 69 | 73 73 69 6f 6e 20 69 73 |d..Permi|ssion is|
|00000100| 20 67 72 61 6e 74 65 64 | 20 66 6f 72 20 75 6e 72 | granted| for unr|
|00000110| 65 73 74 72 69 63 74 65 | 64 20 6e 6f 6e 2d 63 6f |estricte|d non-co|
|00000120| 6d 6d 65 72 63 69 61 6c | 20 75 73 65 09 2a 2f 0d |mmercial| use.*/.|
|00000130| 0d 23 69 6e 63 6c 75 64 | 65 20 22 78 6c 69 73 70 |.#includ|e "xlisp|
|00000140| 2e 68 22 0d 0d 23 69 66 | 64 65 66 20 4d 45 47 41 |.h"..#if|def MEGA|
|00000150| 4d 41 58 0d 6f 76 65 72 | 6c 61 79 20 22 6f 76 65 |MAX.over|lay "ove|
|00000160| 72 66 6c 6f 77 22 0d 23 | 65 6e 64 69 66 0d 0d 2f |rflow".#|endif../|
|00000170| 2a 20 65 78 74 65 72 6e | 61 6c 20 76 61 72 69 61 |* extern|al varia|
|00000180| 62 6c 65 73 20 2a 2f 0d | 65 78 74 65 72 6e 20 4e |bles */.|extern N|
|00000190| 4f 44 45 20 2a 78 6c 65 | 6e 76 3b 0d 65 78 74 65 |ODE *xle|nv;.exte|
|000001a0| 72 6e 20 4e 4f 44 45 20 | 2a 73 5f 65 76 61 6c 68 |rn NODE |*s_evalh|
|000001b0| 6f 6f 6b 2c 2a 73 5f 61 | 70 70 6c 79 68 6f 6f 6b |ook,*s_a|pplyhook|
|000001c0| 3b 0d 65 78 74 65 72 6e | 20 4e 4f 44 45 20 2a 73 |;.extern| NODE *s|
|000001d0| 5f 63 61 72 2c 2a 73 5f | 63 64 72 2c 2a 73 5f 6e |_car,*s_|cdr,*s_n|
|000001e0| 74 68 2c 2a 73 5f 67 65 | 74 2c 2a 73 5f 73 76 61 |th,*s_ge|t,*s_sva|
|000001f0| 6c 75 65 2c 2a 73 5f 73 | 70 6c 69 73 74 2c 2a 73 |lue,*s_s|plist,*s|
|00000200| 5f 61 72 65 66 3b 0d 65 | 78 74 65 72 6e 20 4e 4f |_aref;.e|xtern NO|
|00000210| 44 45 20 2a 73 5f 6c 61 | 6d 62 64 61 2c 2a 73 5f |DE *s_la|mbda,*s_|
|00000220| 6d 61 63 72 6f 3b 0d 65 | 78 74 65 72 6e 20 4e 4f |macro;.e|xtern NO|
|00000230| 44 45 20 2a 73 5f 63 6f | 6d 6d 61 2c 2a 73 5f 63 |DE *s_co|mma,*s_c|
|00000240| 6f 6d 61 74 3b 0d 65 78 | 74 65 72 6e 20 4e 4f 44 |omat;.ex|tern NOD|
|00000250| 45 20 2a 73 5f 75 6e 62 | 6f 75 6e 64 3b 0d 65 78 |E *s_unb|ound;.ex|
|00000260| 74 65 72 6e 20 63 68 61 | 72 20 67 73 70 72 65 66 |tern cha|r gspref|
|00000270| 69 78 5b 5d 3b 0d 65 78 | 74 65 72 6e 20 69 6e 74 |ix[];.ex|tern int|
|00000280| 20 67 73 6e 75 6d 62 65 | 72 3b 0d 0d 2f 2a 20 65 | gsnumbe|r;../* e|
|00000290| 78 74 65 72 6e 61 6c 20 | 72 6f 75 74 69 6e 65 73 |xternal |routines|
|000002a0| 20 2a 2f 0d 65 78 74 65 | 72 6e 20 4e 4f 44 45 20 | */.exte|rn NODE |
|000002b0| 2a 78 6c 78 65 76 61 6c | 28 29 3b 0d 0d 2f 2a 20 |*xlxeval|();../* |
|000002c0| 66 6f 72 77 61 72 64 20 | 64 65 63 6c 61 72 61 74 |forward |declarat|
|000002d0| 69 6f 6e 73 20 2a 2f 0d | 46 4f 52 57 41 52 44 20 |ions */.|FORWARD |
|000002e0| 4e 4f 44 45 20 2a 62 71 | 75 6f 74 65 31 28 29 3b |NODE *bq|uote1();|
|000002f0| 0d 46 4f 52 57 41 52 44 | 20 4e 4f 44 45 20 2a 64 |.FORWARD| NODE *d|
|00000300| 65 66 75 6e 28 29 3b 0d | 46 4f 52 57 41 52 44 20 |efun();.|FORWARD |
|00000310| 4e 4f 44 45 20 2a 6d 61 | 6b 65 73 79 6d 62 6f 6c |NODE *ma|kesymbol|
|00000320| 28 29 3b 0d 0d 2f 2a 20 | 78 65 76 61 6c 20 2d 20 |();../* |xeval - |
|00000330| 74 68 65 20 62 75 69 6c | 74 2d 69 6e 20 66 75 6e |the buil|t-in fun|
|00000340| 63 74 69 6f 6e 20 27 65 | 76 61 6c 27 20 2a 2f 0d |ction 'e|val' */.|
|00000350| 4e 4f 44 45 20 2a 78 65 | 76 61 6c 28 61 72 67 73 |NODE *xe|val(args|
|00000360| 29 0d 20 20 4e 4f 44 45 | 20 2a 61 72 67 73 3b 0d |). NODE| *args;.|
|00000370| 7b 0d 20 20 20 20 4e 4f | 44 45 20 2a 65 78 70 72 |{. NO|DE *expr|
|00000380| 3b 0d 0d 20 20 20 20 2f | 2a 20 67 65 74 20 74 68 |;.. /|* get th|
|00000390| 65 20 65 78 70 72 65 73 | 73 69 6f 6e 20 74 6f 20 |e expres|sion to |
|000003a0| 65 76 61 6c 75 61 74 65 | 20 2a 2f 0d 20 20 20 20 |evaluate| */. |
|000003b0| 65 78 70 72 20 3d 20 78 | 6c 61 72 67 28 26 61 72 |expr = x|larg(&ar|
|000003c0| 67 73 29 3b 0d 20 20 20 | 20 78 6c 6c 61 73 74 61 |gs);. | xllasta|
|000003d0| 72 67 28 61 72 67 73 29 | 3b 0d 0d 20 20 20 20 2f |rg(args)|;.. /|
|000003e0| 2a 20 65 76 61 6c 75 61 | 74 65 20 74 68 65 20 65 |* evalua|te the e|
|000003f0| 78 70 72 65 73 73 69 6f | 6e 20 2a 2f 0d 20 20 20 |xpressio|n */. |
|00000400| 20 72 65 74 75 72 6e 20 | 28 78 6c 65 76 61 6c 28 | return |(xleval(|
|00000410| 65 78 70 72 29 29 3b 0d | 7d 0d 0d 2f 2a 20 78 61 |expr));.|}../* xa|
|00000420| 70 70 6c 79 20 2d 20 74 | 68 65 20 62 75 69 6c 74 |pply - t|he built|
|00000430| 2d 69 6e 20 66 75 6e 63 | 74 69 6f 6e 20 27 61 70 |-in func|tion 'ap|
|00000440| 70 6c 79 27 20 2a 2f 0d | 4e 4f 44 45 20 2a 78 61 |ply' */.|NODE *xa|
|00000450| 70 70 6c 79 28 61 72 67 | 73 29 0d 20 20 4e 4f 44 |pply(arg|s). NOD|
|00000460| 45 20 2a 61 72 67 73 3b | 0d 7b 0d 20 20 20 20 4e |E *args;|.{. N|
|00000470| 4f 44 45 20 2a 2a 2a 6f | 6c 64 73 74 6b 2c 2a 66 |ODE ***o|ldstk,*f|
|00000480| 75 6e 2c 2a 61 72 67 6c | 69 73 74 2c 2a 76 61 6c |un,*argl|ist,*val|
|00000490| 3b 0d 0d 20 20 20 20 2f | 2a 20 63 72 65 61 74 65 |;.. /|* create|
|000004a0| 20 61 20 6e 65 77 20 73 | 74 61 63 6b 20 66 72 61 | a new s|tack fra|
|000004b0| 6d 65 20 2a 2f 0d 20 20 | 20 20 6f 6c 64 73 74 6b |me */. | oldstk|
|000004c0| 20 3d 20 78 6c 73 74 61 | 63 6b 3b 0d 20 20 20 20 | = xlsta|ck;. |
|000004d0| 78 6c 73 61 76 65 31 28 | 66 75 6e 29 3b 0d 0d 20 |xlsave1(|fun);.. |
|000004e0| 20 20 20 2f 2a 20 67 65 | 74 20 74 68 65 20 66 75 | /* ge|t the fu|
|000004f0| 6e 63 74 69 6f 6e 20 61 | 6e 64 20 61 72 67 75 6d |nction a|nd argum|
|00000500| 65 6e 74 20 6c 69 73 74 | 20 2a 2f 0d 20 20 20 20 |ent list| */. |
|00000510| 66 75 6e 20 3d 20 78 6c | 61 72 67 28 26 61 72 67 |fun = xl|arg(&arg|
|00000520| 73 29 3b 0d 20 20 20 20 | 61 72 67 6c 69 73 74 20 |s);. |arglist |
|00000530| 3d 20 78 6c 6d 61 74 63 | 68 28 4c 49 53 54 2c 26 |= xlmatc|h(LIST,&|
|00000540| 61 72 67 73 29 3b 0d 20 | 20 20 20 78 6c 6c 61 73 |args);. | xllas|
|00000550| 74 61 72 67 28 61 72 67 | 73 29 3b 0d 0d 20 20 20 |targ(arg|s);.. |
|00000560| 20 2f 2a 20 69 66 20 74 | 68 65 20 66 75 6e 63 74 | /* if t|he funct|
|00000570| 69 6f 6e 20 69 73 20 61 | 20 73 79 6d 62 6f 6c 2c |ion is a| symbol,|
|00000580| 20 67 65 74 20 69 74 73 | 20 76 61 6c 75 65 20 2a | get its| value *|
|00000590| 2f 0d 20 20 20 20 69 66 | 20 28 73 79 6d 62 6f 6c |/. if| (symbol|
|000005a0| 70 28 66 75 6e 29 29 0d | 09 66 75 6e 20 3d 20 78 |p(fun)).|.fun = x|
|000005b0| 6c 65 76 61 6c 28 66 75 | 6e 29 3b 0d 0d 20 20 20 |leval(fu|n);.. |
|000005c0| 20 2f 2a 20 61 70 70 6c | 79 20 74 68 65 20 66 75 | /* appl|y the fu|
|000005d0| 6e 63 74 69 6f 6e 20 74 | 6f 20 74 68 65 20 61 72 |nction t|o the ar|
|000005e0| 67 75 6d 65 6e 74 73 20 | 2a 2f 0d 20 20 20 20 76 |guments |*/. v|
|000005f0| 61 6c 20 3d 20 78 6c 61 | 70 70 6c 79 28 66 75 6e |al = xla|pply(fun|
|00000600| 2c 61 72 67 6c 69 73 74 | 29 3b 0d 0d 20 20 20 20 |,arglist|);.. |
|00000610| 2f 2a 20 72 65 73 74 6f | 72 65 20 74 68 65 20 70 |/* resto|re the p|
|00000620| 72 65 76 69 6f 75 73 20 | 73 74 61 63 6b 20 66 72 |revious |stack fr|
|00000630| 61 6d 65 20 2a 2f 0d 20 | 20 20 20 78 6c 73 74 61 |ame */. | xlsta|
|00000640| 63 6b 20 3d 20 6f 6c 64 | 73 74 6b 3b 0d 0d 20 20 |ck = old|stk;.. |
|00000650| 20 20 2f 2a 20 72 65 74 | 75 72 6e 20 74 68 65 20 | /* ret|urn the |
|00000660| 65 78 70 72 65 73 73 69 | 6f 6e 20 65 76 61 6c 75 |expressi|on evalu|
|00000670| 61 74 65 64 20 2a 2f 0d | 20 20 20 20 72 65 74 75 |ated */.| retu|
|00000680| 72 6e 20 28 76 61 6c 29 | 3b 0d 7d 0d 0d 2f 2a 20 |rn (val)|;.}../* |
|00000690| 78 66 75 6e 63 61 6c 6c | 20 2d 20 74 68 65 20 62 |xfuncall| - the b|
|000006a0| 75 69 6c 74 2d 69 6e 20 | 66 75 6e 63 74 69 6f 6e |uilt-in |function|
|000006b0| 20 27 66 75 6e 63 61 6c | 6c 27 20 2a 2f 0d 4e 4f | 'funcal|l' */.NO|
|000006c0| 44 45 20 2a 78 66 75 6e | 63 61 6c 6c 28 61 72 67 |DE *xfun|call(arg|
|000006d0| 73 29 0d 20 20 4e 4f 44 | 45 20 2a 61 72 67 73 3b |s). NOD|E *args;|
|000006e0| 0d 7b 0d 20 20 20 20 4e | 4f 44 45 20 2a 2a 2a 6f |.{. N|ODE ***o|
|000006f0| 6c 64 73 74 6b 2c 2a 66 | 75 6e 2c 2a 76 61 6c 3b |ldstk,*f|un,*val;|
|00000700| 0d 0d 20 20 20 20 2f 2a | 20 63 72 65 61 74 65 20 |.. /*| create |
|00000710| 61 20 6e 65 77 20 73 74 | 61 63 6b 20 66 72 61 6d |a new st|ack fram|
|00000720| 65 20 2a 2f 0d 20 20 20 | 20 6f 6c 64 73 74 6b 20 |e */. | oldstk |
|00000730| 3d 20 78 6c 73 74 61 63 | 6b 3b 0d 20 20 20 20 78 |= xlstac|k;. x|
|00000740| 6c 73 61 76 65 31 28 66 | 75 6e 29 3b 0d 0d 20 20 |lsave1(f|un);.. |
|00000750| 20 20 2f 2a 20 67 65 74 | 20 74 68 65 20 66 75 6e | /* get| the fun|
|00000760| 63 74 69 6f 6e 20 28 74 | 68 65 20 72 65 73 74 20 |ction (t|he rest |
|00000770| 6f 66 20 74 68 65 20 61 | 72 67 73 20 69 73 20 74 |of the a|rgs is t|
|00000780| 68 65 20 61 72 67 75 6d | 65 6e 74 20 6c 69 73 74 |he argum|ent list|
|00000790| 29 20 2a 2f 0d 20 20 20 | 20 66 75 6e 20 3d 20 78 |) */. | fun = x|
|000007a0| 6c 61 72 67 28 26 61 72 | 67 73 29 3b 0d 0d 20 20 |larg(&ar|gs);.. |
|000007b0| 20 20 2f 2a 20 69 66 20 | 74 68 65 20 66 75 6e 63 | /* if |the func|
|000007c0| 74 69 6f 6e 20 69 73 20 | 61 20 73 79 6d 62 6f 6c |tion is |a symbol|
|000007d0| 2c 20 67 65 74 20 69 74 | 73 20 76 61 6c 75 65 20 |, get it|s value |
|000007e0| 2a 2f 0d 20 20 20 20 69 | 66 20 28 73 79 6d 62 6f |*/. i|f (symbo|
|000007f0| 6c 70 28 66 75 6e 29 29 | 0d 09 66 75 6e 20 3d 20 |lp(fun))|..fun = |
|00000800| 78 6c 65 76 61 6c 28 66 | 75 6e 29 3b 0d 0d 20 20 |xleval(f|un);.. |
|00000810| 20 20 2f 2a 20 61 70 70 | 6c 79 20 74 68 65 20 66 | /* app|ly the f|
|00000820| 75 6e 63 74 69 6f 6e 20 | 74 6f 20 74 68 65 20 61 |unction |to the a|
|00000830| 72 67 75 6d 65 6e 74 73 | 20 2a 2f 0d 20 20 20 20 |rguments| */. |
|00000840| 76 61 6c 20 3d 20 78 6c | 61 70 70 6c 79 28 66 75 |val = xl|apply(fu|
|00000850| 6e 2c 61 72 67 73 29 3b | 0d 0d 20 20 20 20 2f 2a |n,args);|.. /*|
|00000860| 20 72 65 73 74 6f 72 65 | 20 74 68 65 20 70 72 65 | restore| the pre|
|00000870| 76 69 6f 75 73 20 73 74 | 61 63 6b 20 66 72 61 6d |vious st|ack fram|
|00000880| 65 20 2a 2f 0d 20 20 20 | 20 78 6c 73 74 61 63 6b |e */. | xlstack|
|00000890| 20 3d 20 6f 6c 64 73 74 | 6b 3b 0d 0d 20 20 20 20 | = oldst|k;.. |
|000008a0| 2f 2a 20 72 65 74 75 72 | 6e 20 74 68 65 20 65 78 |/* retur|n the ex|
|000008b0| 70 72 65 73 73 69 6f 6e | 20 65 76 61 6c 75 61 74 |pression| evaluat|
|000008c0| 65 64 20 2a 2f 0d 20 20 | 20 20 72 65 74 75 72 6e |ed */. | return|
|000008d0| 20 28 76 61 6c 29 3b 0d | 7d 0d 0d 2f 2a 20 78 73 | (val);.|}../* xs|
|000008e0| 65 74 20 2d 20 62 75 69 | 6c 74 2d 69 6e 20 66 75 |et - bui|lt-in fu|
|000008f0| 6e 63 74 69 6f 6e 20 73 | 65 74 20 2a 2f 0d 4e 4f |nction s|et */.NO|
|00000900| 44 45 20 2a 78 73 65 74 | 28 61 72 67 73 29 0d 20 |DE *xset|(args). |
|00000910| 20 4e 4f 44 45 20 2a 61 | 72 67 73 3b 0d 7b 0d 20 | NODE *a|rgs;.{. |
|00000920| 20 20 20 4e 4f 44 45 20 | 2a 73 79 6d 2c 2a 76 61 | NODE |*sym,*va|
|00000930| 6c 3b 0d 0d 20 20 20 20 | 2f 2a 20 67 65 74 20 74 |l;.. |/* get t|
|00000940| 68 65 20 73 79 6d 62 6f | 6c 20 61 6e 64 20 6e 65 |he symbo|l and ne|
|00000950| 77 20 76 61 6c 75 65 20 | 2a 2f 0d 20 20 20 20 73 |w value |*/. s|
|00000960| 79 6d 20 3d 20 78 6c 6d | 61 74 63 68 28 53 59 4d |ym = xlm|atch(SYM|
|00000970| 2c 26 61 72 67 73 29 3b | 0d 20 20 20 20 76 61 6c |,&args);|. val|
|00000980| 20 3d 20 78 6c 61 72 67 | 28 26 61 72 67 73 29 3b | = xlarg|(&args);|
|00000990| 0d 20 20 20 20 78 6c 6c | 61 73 74 61 72 67 28 61 |. xll|astarg(a|
|000009a0| 72 67 73 29 3b 0d 0d 20 | 20 20 20 2f 2a 20 61 73 |rgs);.. | /* as|
|000009b0| 73 69 67 6e 20 74 68 65 | 20 73 79 6d 62 6f 6c 20 |sign the| symbol |
|000009c0| 74 68 65 20 76 61 6c 75 | 65 20 6f 66 20 61 72 67 |the valu|e of arg|
|000009d0| 75 6d 65 6e 74 20 32 20 | 61 6e 64 20 74 68 65 20 |ument 2 |and the |
|000009e0| 72 65 74 75 72 6e 20 76 | 61 6c 75 65 20 2a 2f 0d |return v|alue */.|
|000009f0| 20 20 20 20 73 65 74 76 | 61 6c 75 65 28 73 79 6d | setv|alue(sym|
|00000a00| 2c 76 61 6c 29 3b 0d 0d | 20 20 20 20 2f 2a 20 72 |,val);..| /* r|
|00000a10| 65 74 75 72 6e 20 74 68 | 65 20 72 65 73 75 6c 74 |eturn th|e result|
|00000a20| 20 76 61 6c 75 65 20 2a | 2f 0d 20 20 20 20 72 65 | value *|/. re|
|00000a30| 74 75 72 6e 20 28 76 61 | 6c 29 3b 0d 7d 0d 0d 2f |turn (va|l);.}../|
|00000a40| 2a 20 78 67 65 6e 73 79 | 6d 20 2d 20 67 65 6e 65 |* xgensy|m - gene|
|00000a50| 72 61 74 65 20 61 20 73 | 79 6d 62 6f 6c 20 2a 2f |rate a s|ymbol */|
|00000a60| 0d 4e 4f 44 45 20 2a 78 | 67 65 6e 73 79 6d 28 61 |.NODE *x|gensym(a|
|00000a70| 72 67 73 29 0d 20 20 4e | 4f 44 45 20 2a 61 72 67 |rgs). N|ODE *arg|
|00000a80| 73 3b 0d 7b 0d 20 20 20 | 20 63 68 61 72 20 73 79 |s;.{. | char sy|
|00000a90| 6d 5b 53 54 52 4d 41 58 | 2b 31 5d 3b 0d 20 20 20 |m[STRMAX|+1];. |
|00000aa0| 20 4e 4f 44 45 20 2a 78 | 3b 0d 0d 20 20 20 20 2f | NODE *x|;.. /|
|00000ab0| 2a 20 67 65 74 20 74 68 | 65 20 70 72 65 66 69 78 |* get th|e prefix|
|00000ac0| 20 6f 72 20 6e 75 6d 62 | 65 72 20 2a 2f 0d 20 20 | or numb|er */. |
|00000ad0| 20 20 69 66 20 28 61 72 | 67 73 29 20 7b 0d 09 78 | if (ar|gs) {..x|
|00000ae0| 20 3d 20 78 6c 61 72 67 | 28 26 61 72 67 73 29 3b | = xlarg|(&args);|
|00000af0| 0d 09 73 77 69 74 63 68 | 20 28 6e 74 79 70 65 28 |..switch| (ntype(|
|00000b00| 78 29 29 20 7b 0d 09 63 | 61 73 65 20 53 54 52 3a |x)) {..c|ase STR:|
|00000b10| 0d 09 09 73 74 72 63 70 | 79 28 67 73 70 72 65 66 |...strcp|y(gspref|
|00000b20| 69 78 2c 67 65 74 73 74 | 72 69 6e 67 28 78 29 29 |ix,getst|ring(x))|
|00000b30| 3b 0d 09 09 62 72 65 61 | 6b 3b 0d 09 63 61 73 65 |;...brea|k;..case|
|00000b40| 20 49 4e 54 3a 0d 09 09 | 67 73 6e 75 6d 62 65 72 | INT:...|gsnumber|
|00000b50| 20 3d 20 67 65 74 66 69 | 78 6e 75 6d 28 78 29 3b | = getfi|xnum(x);|
|00000b60| 0d 09 09 62 72 65 61 6b | 3b 0d 09 64 65 66 61 75 |...break|;..defau|
|00000b70| 6c 74 3a 0d 09 09 78 6c | 65 72 72 6f 72 28 22 62 |lt:...xl|error("b|
|00000b80| 61 64 20 61 72 67 75 6d | 65 6e 74 20 74 79 70 65 |ad argum|ent type|
|00000b90| 22 2c 78 29 3b 0d 09 7d | 0d 20 20 20 20 7d 0d 20 |",x);..}|. }. |
|00000ba0| 20 20 20 78 6c 6c 61 73 | 74 61 72 67 28 61 72 67 | xllas|targ(arg|
|00000bb0| 73 29 3b 0d 0d 20 20 20 | 20 2f 2a 20 63 72 65 61 |s);.. | /* crea|
|00000bc0| 74 65 20 74 68 65 20 70 | 6e 61 6d 65 20 6f 66 20 |te the p|name of |
|00000bd0| 74 68 65 20 6e 65 77 20 | 73 79 6d 62 6f 6c 20 2a |the new |symbol *|
|00000be0| 2f 0d 20 20 20 20 73 70 | 72 69 6e 74 66 28 73 79 |/. sp|rintf(sy|
|00000bf0| 6d 2c 22 25 73 25 64 22 | 2c 67 73 70 72 65 66 69 |m,"%s%d"|,gsprefi|
|00000c00| 78 2c 67 73 6e 75 6d 62 | 65 72 2b 2b 29 3b 0d 0d |x,gsnumb|er++);..|
|00000c10| 20 20 20 20 2f 2a 20 6d | 61 6b 65 20 61 20 73 79 | /* m|ake a sy|
|00000c20| 6d 62 6f 6c 20 77 69 74 | 68 20 74 68 69 73 20 70 |mbol wit|h this p|
|00000c30| 72 69 6e 74 20 6e 61 6d | 65 20 2a 2f 0d 20 20 20 |rint nam|e */. |
|00000c40| 20 72 65 74 75 72 6e 20 | 28 78 6c 6d 61 6b 65 73 | return |(xlmakes|
|00000c50| 79 6d 28 73 79 6d 2c 44 | 59 4e 41 4d 49 43 29 29 |ym(sym,D|YNAMIC))|
|00000c60| 3b 0d 7d 0d 0d 2f 2a 20 | 78 6d 61 6b 65 73 79 6d |;.}../* |xmakesym|
|00000c70| 62 6f 6c 20 2d 20 6d 61 | 6b 65 20 61 20 6e 65 77 |bol - ma|ke a new|
|00000c80| 20 75 6e 69 6e 74 65 72 | 6e 65 64 20 73 79 6d 62 | uninter|ned symb|
|00000c90| 6f 6c 20 2a 2f 0d 4e 4f | 44 45 20 2a 78 6d 61 6b |ol */.NO|DE *xmak|
|00000ca0| 65 73 79 6d 62 6f 6c 28 | 61 72 67 73 29 0d 20 20 |esymbol(|args). |
|00000cb0| 4e 4f 44 45 20 2a 61 72 | 67 73 3b 0d 7b 0d 20 20 |NODE *ar|gs;.{. |
|00000cc0| 20 20 72 65 74 75 72 6e | 20 28 6d 61 6b 65 73 79 | return| (makesy|
|00000cd0| 6d 62 6f 6c 28 61 72 67 | 73 2c 46 41 4c 53 45 29 |mbol(arg|s,FALSE)|
|00000ce0| 29 3b 0d 7d 0d 0d 2f 2a | 20 78 69 6e 74 65 72 6e |);.}../*| xintern|
|00000cf0| 20 2d 20 6d 61 6b 65 20 | 61 20 6e 65 77 20 69 6e | - make |a new in|
|00000d00| 74 65 72 6e 65 64 20 73 | 79 6d 62 6f 6c 20 2a 2f |terned s|ymbol */|
|00000d10| 0d 4e 4f 44 45 20 2a 78 | 69 6e 74 65 72 6e 28 61 |.NODE *x|intern(a|
|00000d20| 72 67 73 29 0d 20 20 4e | 4f 44 45 20 2a 61 72 67 |rgs). N|ODE *arg|
|00000d30| 73 3b 0d 7b 0d 20 20 20 | 20 72 65 74 75 72 6e 20 |s;.{. | return |
|00000d40| 28 6d 61 6b 65 73 79 6d | 62 6f 6c 28 61 72 67 73 |(makesym|bol(args|
|00000d50| 2c 54 52 55 45 29 29 3b | 0d 7d 0d 0d 2f 2a 20 6d |,TRUE));|.}../* m|
|00000d60| 61 6b 65 73 79 6d 62 6f | 6c 20 2d 20 6d 61 6b 65 |akesymbo|l - make|
|00000d70| 20 61 20 6e 65 77 20 73 | 79 6d 62 6f 6c 20 2a 2f | a new s|ymbol */|
|00000d80| 0d 4c 4f 43 41 4c 20 4e | 4f 44 45 20 2a 6d 61 6b |.LOCAL N|ODE *mak|
|00000d90| 65 73 79 6d 62 6f 6c 28 | 61 72 67 73 2c 69 66 6c |esymbol(|args,ifl|
|00000da0| 61 67 29 0d 20 20 4e 4f | 44 45 20 2a 61 72 67 73 |ag). NO|DE *args|
|00000db0| 3b 20 69 6e 74 20 69 66 | 6c 61 67 3b 0d 7b 0d 20 |; int if|lag;.{. |
|00000dc0| 20 20 20 63 68 61 72 20 | 2a 70 6e 61 6d 65 3b 0d | char |*pname;.|
|00000dd0| 0d 20 20 20 20 2f 2a 20 | 67 65 74 20 74 68 65 20 |. /* |get the |
|00000de0| 70 72 69 6e 74 20 6e 61 | 6d 65 20 6f 66 20 74 68 |print na|me of th|
|00000df0| 65 20 73 79 6d 62 6f 6c | 20 74 6f 20 69 6e 74 65 |e symbol| to inte|
|00000e00| 72 6e 20 2a 2f 0d 20 20 | 20 20 70 6e 61 6d 65 20 |rn */. | pname |
|00000e10| 3d 20 67 65 74 73 74 72 | 69 6e 67 28 78 6c 6d 61 |= getstr|ing(xlma|
|00000e20| 74 63 68 28 53 54 52 2c | 26 61 72 67 73 29 29 3b |tch(STR,|&args));|
|00000e30| 0d 20 20 20 20 78 6c 6c | 61 73 74 61 72 67 28 61 |. xll|astarg(a|
|00000e40| 72 67 73 29 3b 0d 0d 20 | 20 20 20 2f 2a 20 6d 61 |rgs);.. | /* ma|
|00000e50| 6b 65 20 74 68 65 20 73 | 79 6d 62 6f 6c 20 2a 2f |ke the s|ymbol */|
|00000e60| 0d 20 20 20 20 72 65 74 | 75 72 6e 20 28 69 66 6c |. ret|urn (ifl|
|00000e70| 61 67 20 3f 20 78 6c 65 | 6e 74 65 72 28 70 6e 61 |ag ? xle|nter(pna|
|00000e80| 6d 65 2c 44 59 4e 41 4d | 49 43 29 20 3a 20 78 6c |me,DYNAM|IC) : xl|
|00000e90| 6d 61 6b 65 73 79 6d 28 | 70 6e 61 6d 65 2c 44 59 |makesym(|pname,DY|
|00000ea0| 4e 41 4d 49 43 29 29 3b | 0d 7d 0d 0d 2f 2a 20 78 |NAMIC));|.}../* x|
|00000eb0| 73 79 6d 6e 61 6d 65 20 | 2d 20 67 65 74 20 74 68 |symname |- get th|
|00000ec0| 65 20 70 72 69 6e 74 20 | 6e 61 6d 65 20 6f 66 20 |e print |name of |
|00000ed0| 61 20 73 79 6d 62 6f 6c | 20 2a 2f 0d 4e 4f 44 45 |a symbol| */.NODE|
|00000ee0| 20 2a 78 73 79 6d 6e 61 | 6d 65 28 61 72 67 73 29 | *xsymna|me(args)|
|00000ef0| 0d 20 20 4e 4f 44 45 20 | 2a 61 72 67 73 3b 0d 7b |. NODE |*args;.{|
|00000f00| 0d 20 20 20 20 4e 4f 44 | 45 20 2a 73 79 6d 3b 0d |. NOD|E *sym;.|
|00000f10| 0d 20 20 20 20 2f 2a 20 | 67 65 74 20 74 68 65 20 |. /* |get the |
|00000f20| 73 79 6d 62 6f 6c 20 2a | 2f 0d 20 20 20 20 73 79 |symbol *|/. sy|
|00000f30| 6d 20 3d 20 78 6c 6d 61 | 74 63 68 28 53 59 4d 2c |m = xlma|tch(SYM,|
|00000f40| 26 61 72 67 73 29 3b 0d | 20 20 20 20 78 6c 6c 61 |&args);.| xlla|
|00000f50| 73 74 61 72 67 28 61 72 | 67 73 29 3b 0d 0d 20 20 |starg(ar|gs);.. |
|00000f60| 20 20 2f 2a 20 72 65 74 | 75 72 6e 20 74 68 65 20 | /* ret|urn the |
|00000f70| 70 72 69 6e 74 20 6e 61 | 6d 65 20 2a 2f 0d 20 20 |print na|me */. |
|00000f80| 20 20 72 65 74 75 72 6e | 20 28 67 65 74 70 6e 61 | return| (getpna|
|00000f90| 6d 65 28 73 79 6d 29 29 | 3b 0d 7d 0d 0d 2f 2a 20 |me(sym))|;.}../* |
|00000fa0| 78 73 79 6d 76 61 6c 75 | 65 20 2d 20 67 65 74 20 |xsymvalu|e - get |
|00000fb0| 74 68 65 20 76 61 6c 75 | 65 20 6f 66 20 61 20 73 |the valu|e of a s|
|00000fc0| 79 6d 62 6f 6c 20 2a 2f | 0d 4e 4f 44 45 20 2a 78 |ymbol */|.NODE *x|
|00000fd0| 73 79 6d 76 61 6c 75 65 | 28 61 72 67 73 29 0d 20 |symvalue|(args). |
|00000fe0| 20 4e 4f 44 45 20 2a 61 | 72 67 73 3b 0d 7b 0d 20 | NODE *a|rgs;.{. |
|00000ff0| 20 20 20 4e 4f 44 45 20 | 2a 73 79 6d 2c 2a 76 61 | NODE |*sym,*va|
|00001000| 6c 3b 0d 0d 20 20 20 20 | 2f 2a 20 67 65 74 20 74 |l;.. |/* get t|
|00001010| 68 65 20 73 79 6d 62 6f | 6c 20 2a 2f 0d 20 20 20 |he symbo|l */. |
|00001020| 20 73 79 6d 20 3d 20 78 | 6c 6d 61 74 63 68 28 53 | sym = x|lmatch(S|
|00001030| 59 4d 2c 26 61 72 67 73 | 29 3b 0d 20 20 20 20 78 |YM,&args|);. x|
|00001040| 6c 6c 61 73 74 61 72 67 | 28 61 72 67 73 29 3b 0d |llastarg|(args);.|
|00001050| 0d 20 20 20 20 2f 2a 20 | 67 65 74 20 74 68 65 20 |. /* |get the |
|00001060| 67 6c 6f 62 61 6c 20 76 | 61 6c 75 65 20 2a 2f 0d |global v|alue */.|
|00001070| 20 20 20 20 77 68 69 6c | 65 20 28 28 76 61 6c 20 | whil|e ((val |
|00001080| 3d 20 67 65 74 76 61 6c | 75 65 28 73 79 6d 29 29 |= getval|ue(sym))|
|00001090| 20 3d 3d 20 73 5f 75 6e | 62 6f 75 6e 64 29 0d 09 | == s_un|bound)..|
|000010a0| 78 6c 63 65 72 72 6f 72 | 28 22 74 72 79 20 65 76 |xlcerror|("try ev|
|000010b0| 61 6c 75 61 74 69 6e 67 | 20 73 79 6d 62 6f 6c 20 |aluating| symbol |
|000010c0| 61 67 61 69 6e 22 2c 22 | 75 6e 62 6f 75 6e 64 20 |again","|unbound |
|000010d0| 76 61 72 69 61 62 6c 65 | 22 2c 73 79 6d 29 3b 0d |variable|",sym);.|
|000010e0| 0d 20 20 20 20 2f 2a 20 | 72 65 74 75 72 6e 20 69 |. /* |return i|
|000010f0| 74 73 20 76 61 6c 75 65 | 20 2a 2f 0d 20 20 20 20 |ts value| */. |
|00001100| 72 65 74 75 72 6e 20 28 | 76 61 6c 29 3b 0d 7d 0d |return (|val);.}.|
|00001110| 0d 2f 2a 20 78 73 79 6d | 70 6c 69 73 74 20 2d 20 |./* xsym|plist - |
|00001120| 67 65 74 20 74 68 65 20 | 70 72 6f 70 65 72 74 79 |get the |property|
|00001130| 20 6c 69 73 74 20 6f 66 | 20 61 20 73 79 6d 62 6f | list of| a symbo|
|00001140| 6c 20 2a 2f 0d 4e 4f 44 | 45 20 2a 78 73 79 6d 70 |l */.NOD|E *xsymp|
|00001150| 6c 69 73 74 28 61 72 67 | 73 29 0d 20 20 4e 4f 44 |list(arg|s). NOD|
|00001160| 45 20 2a 61 72 67 73 3b | 0d 7b 0d 20 20 20 20 4e |E *args;|.{. N|
|00001170| 4f 44 45 20 2a 73 79 6d | 3b 0d 0d 20 20 20 20 2f |ODE *sym|;.. /|
|00001180| 2a 20 67 65 74 20 74 68 | 65 20 73 79 6d 62 6f 6c |* get th|e symbol|
|00001190| 20 2a 2f 0d 20 20 20 20 | 73 79 6d 20 3d 20 78 6c | */. |sym = xl|
|000011a0| 6d 61 74 63 68 28 53 59 | 4d 2c 26 61 72 67 73 29 |match(SY|M,&args)|
|000011b0| 3b 0d 20 20 20 20 78 6c | 6c 61 73 74 61 72 67 28 |;. xl|lastarg(|
|000011c0| 61 72 67 73 29 3b 0d 0d | 20 20 20 20 2f 2a 20 72 |args);..| /* r|
|000011d0| 65 74 75 72 6e 20 74 68 | 65 20 70 72 6f 70 65 72 |eturn th|e proper|
|000011e0| 74 79 20 6c 69 73 74 20 | 2a 2f 0d 20 20 20 20 72 |ty list |*/. r|
|000011f0| 65 74 75 72 6e 20 28 67 | 65 74 70 6c 69 73 74 28 |eturn (g|etplist(|
|00001200| 73 79 6d 29 29 3b 0d 7d | 0d 0d 2f 2a 20 78 67 65 |sym));.}|../* xge|
|00001210| 74 20 2d 20 67 65 74 20 | 74 68 65 20 76 61 6c 75 |t - get |the valu|
|00001220| 65 20 6f 66 20 61 20 70 | 72 6f 70 65 72 74 79 20 |e of a p|roperty |
|00001230| 2a 2f 0d 4e 4f 44 45 20 | 2a 78 67 65 74 28 61 72 |*/.NODE |*xget(ar|
|00001240| 67 73 29 0d 20 20 4e 4f | 44 45 20 2a 61 72 67 73 |gs). NO|DE *args|
|00001250| 3b 0d 7b 0d 20 20 20 20 | 4e 4f 44 45 20 2a 73 79 |;.{. |NODE *sy|
|00001260| 6d 2c 2a 70 72 70 3b 0d | 0d 20 20 20 20 2f 2a 20 |m,*prp;.|. /* |
|00001270| 67 65 74 20 74 68 65 20 | 73 79 6d 62 6f 6c 20 61 |get the |symbol a|
|00001280| 6e 64 20 70 72 6f 70 65 | 72 74 79 20 2a 2f 0d 20 |nd prope|rty */. |
|00001290| 20 20 20 73 79 6d 20 3d | 20 78 6c 6d 61 74 63 68 | sym =| xlmatch|
|000012a0| 28 53 59 4d 2c 26 61 72 | 67 73 29 3b 0d 20 20 20 |(SYM,&ar|gs);. |
|000012b0| 20 70 72 70 20 3d 20 78 | 6c 6d 61 74 63 68 28 53 | prp = x|lmatch(S|
|000012c0| 59 4d 2c 26 61 72 67 73 | 29 3b 0d 20 20 20 20 78 |YM,&args|);. x|
|000012d0| 6c 6c 61 73 74 61 72 67 | 28 61 72 67 73 29 3b 0d |llastarg|(args);.|
|000012e0| 0d 20 20 20 20 2f 2a 20 | 72 65 74 72 69 65 76 65 |. /* |retrieve|
|000012f0| 20 74 68 65 20 70 72 6f | 70 65 72 74 79 20 76 61 | the pro|perty va|
|00001300| 6c 75 65 20 2a 2f 0d 20 | 20 20 20 72 65 74 75 72 |lue */. | retur|
|00001310| 6e 20 28 78 6c 67 65 74 | 70 72 6f 70 28 73 79 6d |n (xlget|prop(sym|
|00001320| 2c 70 72 70 29 29 3b 0d | 7d 0d 0d 2f 2a 20 78 70 |,prp));.|}../* xp|
|00001330| 75 74 70 72 6f 70 20 2d | 20 73 65 74 20 74 68 65 |utprop -| set the|
|00001340| 20 76 61 6c 75 65 20 6f | 66 20 61 20 70 72 6f 70 | value o|f a prop|
|00001350| 65 72 74 79 20 2a 2f 0d | 4e 4f 44 45 20 2a 78 70 |erty */.|NODE *xp|
|00001360| 75 74 70 72 6f 70 28 61 | 72 67 73 29 0d 20 20 4e |utprop(a|rgs). N|
|00001370| 4f 44 45 20 2a 61 72 67 | 73 3b 0d 7b 0d 20 20 20 |ODE *arg|s;.{. |
|00001380| 20 4e 4f 44 45 20 2a 73 | 79 6d 2c 2a 76 61 6c 2c | NODE *s|ym,*val,|
|00001390| 2a 70 72 70 3b 0d 0d 20 | 20 20 20 2f 2a 20 67 65 |*prp;.. | /* ge|
|000013a0| 74 20 74 68 65 20 73 79 | 6d 62 6f 6c 20 61 6e 64 |t the sy|mbol and|
|000013b0| 20 70 72 6f 70 65 72 74 | 79 20 2a 2f 0d 20 20 20 | propert|y */. |
|000013c0| 20 73 79 6d 20 3d 20 78 | 6c 6d 61 74 63 68 28 53 | sym = x|lmatch(S|
|000013d0| 59 4d 2c 26 61 72 67 73 | 29 3b 0d 20 20 20 20 76 |YM,&args|);. v|
|000013e0| 61 6c 20 3d 20 78 6c 61 | 72 67 28 26 61 72 67 73 |al = xla|rg(&args|
|000013f0| 29 3b 0d 20 20 20 20 70 | 72 70 20 3d 20 78 6c 6d |);. p|rp = xlm|
|00001400| 61 74 63 68 28 53 59 4d | 2c 26 61 72 67 73 29 3b |atch(SYM|,&args);|
|00001410| 0d 20 20 20 20 78 6c 6c | 61 73 74 61 72 67 28 61 |. xll|astarg(a|
|00001420| 72 67 73 29 3b 0d 0d 20 | 20 20 20 2f 2a 20 73 65 |rgs);.. | /* se|
|00001430| 74 20 74 68 65 20 70 72 | 6f 70 65 72 74 79 20 76 |t the pr|operty v|
|00001440| 61 6c 75 65 20 2a 2f 0d | 20 20 20 20 78 6c 70 75 |alue */.| xlpu|
|00001450| 74 70 72 6f 70 28 73 79 | 6d 2c 76 61 6c 2c 70 72 |tprop(sy|m,val,pr|
|00001460| 70 29 3b 0d 0d 20 20 20 | 20 2f 2a 20 72 65 74 75 |p);.. | /* retu|
|00001470| 72 6e 20 74 68 65 20 76 | 61 6c 75 65 20 2a 2f 0d |rn the v|alue */.|
|00001480| 20 20 20 20 72 65 74 75 | 72 6e 20 28 76 61 6c 29 | retu|rn (val)|
|00001490| 3b 0d 7d 0d 0d 2f 2a 20 | 78 72 65 6d 70 72 6f 70 |;.}../* |xremprop|
|000014a0| 20 2d 20 72 65 6d 6f 76 | 65 20 61 20 70 72 6f 70 | - remov|e a prop|
|000014b0| 65 72 74 79 20 76 61 6c | 75 65 20 66 72 6f 6d 20 |erty val|ue from |
|000014c0| 61 20 70 72 6f 70 65 72 | 74 79 20 6c 69 73 74 20 |a proper|ty list |
|000014d0| 2a 2f 0d 4e 4f 44 45 20 | 2a 78 72 65 6d 70 72 6f |*/.NODE |*xrempro|
|000014e0| 70 28 61 72 67 73 29 0d | 20 20 4e 4f 44 45 20 2a |p(args).| NODE *|
|000014f0| 61 72 67 73 3b 0d 7b 0d | 20 20 20 20 4e 4f 44 45 |args;.{.| NODE|
|00001500| 20 2a 73 79 6d 2c 2a 70 | 72 70 3b 0d 0d 20 20 20 | *sym,*p|rp;.. |
|00001510| 20 2f 2a 20 67 65 74 20 | 74 68 65 20 73 79 6d 62 | /* get |the symb|
|00001520| 6f 6c 20 61 6e 64 20 70 | 72 6f 70 65 72 74 79 20 |ol and p|roperty |
|00001530| 2a 2f 0d 20 20 20 20 73 | 79 6d 20 3d 20 78 6c 6d |*/. s|ym = xlm|
|00001540| 61 74 63 68 28 53 59 4d | 2c 26 61 72 67 73 29 3b |atch(SYM|,&args);|
|00001550| 0d 20 20 20 20 70 72 70 | 20 3d 20 78 6c 6d 61 74 |. prp| = xlmat|
|00001560| 63 68 28 53 59 4d 2c 26 | 61 72 67 73 29 3b 0d 20 |ch(SYM,&|args);. |
|00001570| 20 20 20 78 6c 6c 61 73 | 74 61 72 67 28 61 72 67 | xllas|targ(arg|
|00001580| 73 29 3b 0d 0d 20 20 20 | 20 2f 2a 20 72 65 6d 6f |s);.. | /* remo|
|00001590| 76 65 20 74 68 65 20 70 | 72 6f 70 65 72 74 79 20 |ve the p|roperty |
|000015a0| 2a 2f 0d 20 20 20 20 78 | 6c 72 65 6d 70 72 6f 70 |*/. x|lremprop|
|000015b0| 28 73 79 6d 2c 70 72 70 | 29 3b 0d 0d 20 20 20 20 |(sym,prp|);.. |
|000015c0| 2f 2a 20 72 65 74 75 72 | 6e 20 6e 69 6c 20 2a 2f |/* retur|n nil */|
|000015d0| 0d 20 20 20 20 72 65 74 | 75 72 6e 20 28 4e 49 4c |. ret|urn (NIL|
|000015e0| 29 3b 0d 7d 0d 0d 2f 2a | 20 78 68 61 73 68 20 2d |);.}../*| xhash -|
|000015f0| 20 63 6f 6d 70 75 74 65 | 20 74 68 65 20 68 61 73 | compute| the has|
|00001600| 68 20 76 61 6c 75 65 20 | 6f 66 20 61 20 73 74 72 |h value |of a str|
|00001610| 69 6e 67 20 6f 72 20 73 | 79 6d 62 6f 6c 20 2a 2f |ing or s|ymbol */|
|00001620| 0d 4e 4f 44 45 20 2a 78 | 68 61 73 68 28 61 72 67 |.NODE *x|hash(arg|
|00001630| 73 29 0d 20 20 4e 4f 44 | 45 20 2a 61 72 67 73 3b |s). NOD|E *args;|
|00001640| 0d 7b 0d 20 20 20 20 63 | 68 61 72 20 2a 73 74 72 |.{. c|har *str|
|00001650| 3b 0d 20 20 20 20 4e 4f | 44 45 20 2a 76 61 6c 3b |;. NO|DE *val;|
|00001660| 0d 20 20 20 20 69 6e 74 | 20 6c 65 6e 3b 0d 0d 20 |. int| len;.. |
|00001670| 20 20 20 2f 2a 20 67 65 | 74 20 74 68 65 20 73 74 | /* ge|t the st|
|00001680| 72 69 6e 67 20 61 6e 64 | 20 74 68 65 20 74 61 62 |ring and| the tab|
|00001690| 6c 65 20 6c 65 6e 67 74 | 68 20 2a 2f 0d 20 20 20 |le lengt|h */. |
|000016a0| 20 76 61 6c 20 3d 20 78 | 6c 61 72 67 28 26 61 72 | val = x|larg(&ar|
|000016b0| 67 73 29 3b 0d 20 20 20 | 20 6c 65 6e 20 3d 20 28 |gs);. | len = (|
|000016c0| 69 6e 74 29 67 65 74 66 | 69 78 6e 75 6d 28 78 6c |int)getf|ixnum(xl|
|000016d0| 6d 61 74 63 68 28 49 4e | 54 2c 26 61 72 67 73 29 |match(IN|T,&args)|
|000016e0| 29 3b 0d 20 20 20 20 78 | 6c 6c 61 73 74 61 72 67 |);. x|llastarg|
|000016f0| 28 61 72 67 73 29 3b 0d | 0d 20 20 20 20 2f 2a 20 |(args);.|. /* |
|00001700| 67 65 74 20 74 68 65 20 | 73 74 72 69 6e 67 20 2a |get the |string *|
|00001710| 2f 0d 20 20 20 20 69 66 | 20 28 73 79 6d 62 6f 6c |/. if| (symbol|
|00001720| 70 28 76 61 6c 29 29 0d | 09 73 74 72 20 3d 20 67 |p(val)).|.str = g|
|00001730| 65 74 73 74 72 69 6e 67 | 28 67 65 74 70 6e 61 6d |etstring|(getpnam|
|00001740| 65 28 76 61 6c 29 29 3b | 0d 20 20 20 20 65 6c 73 |e(val));|. els|
|00001750| 65 20 69 66 20 28 73 74 | 72 69 6e 67 70 28 76 61 |e if (st|ringp(va|
|00001760| 6c 29 29 0d 09 73 74 72 | 20 3d 20 67 65 74 73 74 |l))..str| = getst|
|00001770| 72 69 6e 67 28 76 61 6c | 29 3b 0d 20 20 20 20 65 |ring(val|);. e|
|00001780| 6c 73 65 0d 09 78 6c 65 | 72 72 6f 72 28 22 62 61 |lse..xle|rror("ba|
|00001790| 64 20 61 72 67 75 6d 65 | 6e 74 20 74 79 70 65 22 |d argume|nt type"|
|000017a0| 2c 76 61 6c 29 3b 0d 0d | 20 20 20 20 2f 2a 20 72 |,val);..| /* r|
|000017b0| 65 74 75 72 6e 20 74 68 | 65 20 68 61 73 68 20 69 |eturn th|e hash i|
|000017c0| 6e 64 65 78 20 2a 2f 0d | 20 20 20 20 72 65 74 75 |ndex */.| retu|
|000017d0| 72 6e 20 28 63 76 66 69 | 78 6e 75 6d 28 28 46 49 |rn (cvfi|xnum((FI|
|000017e0| 58 4e 55 4d 29 68 61 73 | 68 28 73 74 72 2c 6c 65 |XNUM)has|h(str,le|
|000017f0| 6e 29 29 29 3b 0d 7d 0d | 0d 2f 2a 20 78 61 72 65 |n)));.}.|./* xare|
|00001800| 66 20 2d 20 61 72 72 61 | 79 20 72 65 66 65 72 65 |f - arra|y refere|
|00001810| 6e 63 65 20 66 75 6e 63 | 74 69 6f 6e 20 2a 2f 0d |nce func|tion */.|
|00001820| 4e 4f 44 45 20 2a 78 61 | 72 65 66 28 61 72 67 73 |NODE *xa|ref(args|
|00001830| 29 0d 20 20 4e 4f 44 45 | 20 2a 61 72 67 73 3b 0d |). NODE| *args;.|
|00001840| 7b 0d 20 20 20 20 4e 4f | 44 45 20 2a 61 72 72 61 |{. NO|DE *arra|
|00001850| 79 2c 2a 69 6e 64 65 78 | 3b 0d 20 20 20 20 69 6e |y,*index|;. in|
|00001860| 74 20 69 3b 0d 0d 20 20 | 20 20 2f 2a 20 67 65 74 |t i;.. | /* get|
|00001870| 20 74 68 65 20 61 72 72 | 61 79 20 61 6e 64 20 74 | the arr|ay and t|
|00001880| 68 65 20 69 6e 64 65 78 | 20 2a 2f 0d 20 20 20 20 |he index| */. |
|00001890| 61 72 72 61 79 20 3d 20 | 78 6c 6d 61 74 63 68 28 |array = |xlmatch(|
|000018a0| 56 45 43 54 2c 26 61 72 | 67 73 29 3b 0d 20 20 20 |VECT,&ar|gs);. |
|000018b0| 20 69 6e 64 65 78 20 3d | 20 78 6c 6d 61 74 63 68 | index =| xlmatch|
|000018c0| 28 49 4e 54 2c 26 61 72 | 67 73 29 3b 20 69 20 3d |(INT,&ar|gs); i =|
|000018d0| 20 28 69 6e 74 29 67 65 | 74 66 69 78 6e 75 6d 28 | (int)ge|tfixnum(|
|000018e0| 69 6e 64 65 78 29 3b 0d | 20 20 20 20 78 6c 6c 61 |index);.| xlla|
|000018f0| 73 74 61 72 67 28 61 72 | 67 73 29 3b 0d 0d 20 20 |starg(ar|gs);.. |
|00001900| 20 20 2f 2a 20 72 61 6e | 67 65 20 63 68 65 63 6b | /* ran|ge check|
|00001910| 20 74 68 65 20 69 6e 64 | 65 78 20 2a 2f 0d 20 20 | the ind|ex */. |
|00001920| 20 20 69 66 20 28 69 20 | 3c 20 30 20 7c 7c 20 69 | if (i |< 0 || i|
|00001930| 20 3e 3d 20 67 65 74 73 | 69 7a 65 28 61 72 72 61 | >= gets|ize(arra|
|00001940| 79 29 29 0d 09 78 6c 65 | 72 72 6f 72 28 22 61 72 |y))..xle|rror("ar|
|00001950| 72 61 79 20 69 6e 64 65 | 78 20 6f 75 74 20 6f 66 |ray inde|x out of|
|00001960| 20 62 6f 75 6e 64 73 22 | 2c 69 6e 64 65 78 29 3b | bounds"|,index);|
|00001970| 0d 0d 20 20 20 20 2f 2a | 20 72 65 74 75 72 6e 20 |.. /*| return |
|00001980| 74 68 65 20 61 72 72 61 | 79 20 65 6c 65 6d 65 6e |the arra|y elemen|
|00001990| 74 20 2a 2f 0d 20 20 20 | 20 72 65 74 75 72 6e 20 |t */. | return |
|000019a0| 28 67 65 74 65 6c 65 6d | 65 6e 74 28 61 72 72 61 |(getelem|ent(arra|
|000019b0| 79 2c 69 29 29 3b 0d 7d | 0d 0d 2f 2a 20 78 6d 6b |y,i));.}|../* xmk|
|000019c0| 61 72 72 61 79 20 2d 20 | 6d 61 6b 65 20 61 20 6e |array - |make a n|
|000019d0| 65 77 20 61 72 72 61 79 | 20 2a 2f 0d 4e 4f 44 45 |ew array| */.NODE|
|000019e0| 20 2a 78 6d 6b 61 72 72 | 61 79 28 61 72 67 73 29 | *xmkarr|ay(args)|
|000019f0| 0d 20 20 4e 4f 44 45 20 | 2a 61 72 67 73 3b 0d 7b |. NODE |*args;.{|
|00001a00| 0d 20 20 20 20 69 6e 74 | 20 73 69 7a 65 3b 0d 0d |. int| size;..|
|00001a10| 20 20 20 20 2f 2a 20 67 | 65 74 20 74 68 65 20 73 | /* g|et the s|
|00001a20| 69 7a 65 20 6f 66 20 74 | 68 65 20 61 72 72 61 79 |ize of t|he array|
|00001a30| 20 2a 2f 0d 20 20 20 20 | 73 69 7a 65 20 3d 20 28 | */. |size = (|
|00001a40| 69 6e 74 29 67 65 74 66 | 69 78 6e 75 6d 28 78 6c |int)getf|ixnum(xl|
|00001a50| 6d 61 74 63 68 28 49 4e | 54 2c 26 61 72 67 73 29 |match(IN|T,&args)|
|00001a60| 29 3b 0d 20 20 20 20 78 | 6c 6c 61 73 74 61 72 67 |);. x|llastarg|
|00001a70| 28 61 72 67 73 29 3b 0d | 0d 20 20 20 20 2f 2a 20 |(args);.|. /* |
|00001a80| 63 72 65 61 74 65 20 74 | 68 65 20 61 72 72 61 79 |create t|he array|
|00001a90| 20 2a 2f 0d 20 20 20 20 | 72 65 74 75 72 6e 20 28 | */. |return (|
|00001aa0| 6e 65 77 76 65 63 74 6f | 72 28 73 69 7a 65 29 29 |newvecto|r(size))|
|00001ab0| 3b 0d 7d 0d 0d 2f 2a 20 | 78 65 72 72 6f 72 20 2d |;.}../* |xerror -|
|00001ac0| 20 73 70 65 63 69 61 6c | 20 66 6f 72 6d 20 27 65 | special| form 'e|
|00001ad0| 72 72 6f 72 27 20 2a 2f | 0d 4e 4f 44 45 20 2a 78 |rror' */|.NODE *x|
|00001ae0| 65 72 72 6f 72 28 61 72 | 67 73 29 0d 20 20 4e 4f |error(ar|gs). NO|
|00001af0| 44 45 20 2a 61 72 67 73 | 3b 0d 7b 0d 20 20 20 20 |DE *args|;.{. |
|00001b00| 63 68 61 72 20 2a 65 6d | 73 67 3b 20 4e 4f 44 45 |char *em|sg; NODE|
|00001b10| 20 2a 61 72 67 3b 0d 0d | 20 20 20 20 2f 2a 20 67 | *arg;..| /* g|
|00001b20| 65 74 20 74 68 65 20 65 | 72 72 6f 72 20 6d 65 73 |et the e|rror mes|
|00001b30| 73 61 67 65 20 61 6e 64 | 20 74 68 65 20 61 72 67 |sage and| the arg|
|00001b40| 75 6d 65 6e 74 20 2a 2f | 0d 20 20 20 20 65 6d 73 |ument */|. ems|
|00001b50| 67 20 3d 20 67 65 74 73 | 74 72 69 6e 67 28 78 6c |g = gets|tring(xl|
|00001b60| 6d 61 74 63 68 28 53 54 | 52 2c 26 61 72 67 73 29 |match(ST|R,&args)|
|00001b70| 29 3b 0d 20 20 20 20 61 | 72 67 20 3d 20 28 61 72 |);. a|rg = (ar|
|00001b80| 67 73 20 3f 20 78 6c 61 | 72 67 28 26 61 72 67 73 |gs ? xla|rg(&args|
|00001b90| 29 20 3a 20 73 5f 75 6e | 62 6f 75 6e 64 29 3b 0d |) : s_un|bound);.|
|00001ba0| 20 20 20 20 78 6c 6c 61 | 73 74 61 72 67 28 61 72 | xlla|starg(ar|
|00001bb0| 67 73 29 3b 0d 0d 20 20 | 20 20 2f 2a 20 73 69 67 |gs);.. | /* sig|
|00001bc0| 6e 61 6c 20 74 68 65 20 | 65 72 72 6f 72 20 2a 2f |nal the |error */|
|00001bd0| 0d 20 20 20 20 78 6c 65 | 72 72 6f 72 28 65 6d 73 |. xle|rror(ems|
|00001be0| 67 2c 61 72 67 29 3b 0d | 7d 0d 0d 2f 2a 20 78 63 |g,arg);.|}../* xc|
|00001bf0| 65 72 72 6f 72 20 2d 20 | 73 70 65 63 69 61 6c 20 |error - |special |
|00001c00| 66 6f 72 6d 20 27 63 65 | 72 72 6f 72 27 20 2a 2f |form 'ce|rror' */|
|00001c10| 0d 4e 4f 44 45 20 2a 78 | 63 65 72 72 6f 72 28 61 |.NODE *x|cerror(a|
|00001c20| 72 67 73 29 0d 20 20 4e | 4f 44 45 20 2a 61 72 67 |rgs). N|ODE *arg|
|00001c30| 73 3b 0d 7b 0d 20 20 20 | 20 63 68 61 72 20 2a 63 |s;.{. | char *c|
|00001c40| 6d 73 67 2c 2a 65 6d 73 | 67 3b 20 4e 4f 44 45 20 |msg,*ems|g; NODE |
|00001c50| 2a 61 72 67 3b 0d 0d 20 | 20 20 20 2f 2a 20 67 65 |*arg;.. | /* ge|
|00001c60| 74 20 74 68 65 20 63 6f | 72 72 65 63 74 69 6f 6e |t the co|rrection|
|00001c70| 20 6d 65 73 73 61 67 65 | 2c 20 74 68 65 20 65 72 | message|, the er|
|00001c80| 72 6f 72 20 6d 65 73 73 | 61 67 65 2c 20 61 6e 64 |ror mess|age, and|
|00001c90| 20 74 68 65 20 61 72 67 | 75 6d 65 6e 74 20 2a 2f | the arg|ument */|
|00001ca0| 0d 20 20 20 20 63 6d 73 | 67 20 3d 20 67 65 74 73 |. cms|g = gets|
|00001cb0| 74 72 69 6e 67 28 78 6c | 6d 61 74 63 68 28 53 54 |tring(xl|match(ST|
|00001cc0| 52 2c 26 61 72 67 73 29 | 29 3b 0d 20 20 20 20 65 |R,&args)|);. e|
|00001cd0| 6d 73 67 20 3d 20 67 65 | 74 73 74 72 69 6e 67 28 |msg = ge|tstring(|
|00001ce0| 78 6c 6d 61 74 63 68 28 | 53 54 52 2c 26 61 72 67 |xlmatch(|STR,&arg|
|00001cf0| 73 29 29 3b 0d 20 20 20 | 20 61 72 67 20 3d 20 28 |s));. | arg = (|
|00001d00| 61 72 67 73 20 3f 20 78 | 6c 61 72 67 28 26 61 72 |args ? x|larg(&ar|
|00001d10| 67 73 29 20 3a 20 73 5f | 75 6e 62 6f 75 6e 64 29 |gs) : s_|unbound)|
|00001d20| 3b 0d 20 20 20 20 78 6c | 6c 61 73 74 61 72 67 28 |;. xl|lastarg(|
|00001d30| 61 72 67 73 29 3b 0d 0d | 20 20 20 20 2f 2a 20 73 |args);..| /* s|
|00001d40| 69 67 6e 61 6c 20 74 68 | 65 20 65 72 72 6f 72 20 |ignal th|e error |
|00001d50| 2a 2f 0d 20 20 20 20 78 | 6c 63 65 72 72 6f 72 28 |*/. x|lcerror(|
|00001d60| 63 6d 73 67 2c 65 6d 73 | 67 2c 61 72 67 29 3b 0d |cmsg,ems|g,arg);.|
|00001d70| 0d 20 20 20 20 2f 2a 20 | 72 65 74 75 72 6e 20 6e |. /* |return n|
|00001d80| 69 6c 20 2a 2f 0d 20 20 | 20 20 72 65 74 75 72 6e |il */. | return|
|00001d90| 20 28 4e 49 4c 29 3b 0d | 7d 0d 0d 2f 2a 20 78 62 | (NIL);.|}../* xb|
|00001da0| 72 65 61 6b 20 2d 20 73 | 70 65 63 69 61 6c 20 66 |reak - s|pecial f|
|00001db0| 6f 72 6d 20 27 62 72 65 | 61 6b 27 20 2a 2f 0d 4e |orm 'bre|ak' */.N|
|00001dc0| 4f 44 45 20 2a 78 62 72 | 65 61 6b 28 61 72 67 73 |ODE *xbr|eak(args|
|00001dd0| 29 0d 20 20 4e 4f 44 45 | 20 2a 61 72 67 73 3b 0d |). NODE| *args;.|
|00001de0| 7b 0d 20 20 20 20 63 68 | 61 72 20 2a 65 6d 73 67 |{. ch|ar *emsg|
|00001df0| 3b 20 4e 4f 44 45 20 2a | 61 72 67 3b 0d 0d 20 20 |; NODE *|arg;.. |
|00001e00| 20 20 2f 2a 20 67 65 74 | 20 74 68 65 20 65 72 72 | /* get| the err|
|00001e10| 6f 72 20 6d 65 73 73 61 | 67 65 20 2a 2f 0d 20 20 |or messa|ge */. |
|00001e20| 20 20 65 6d 73 67 20 3d | 20 28 61 72 67 73 20 3f | emsg =| (args ?|
|00001e30| 20 67 65 74 73 74 72 69 | 6e 67 28 78 6c 6d 61 74 | getstri|ng(xlmat|
|00001e40| 63 68 28 53 54 52 2c 26 | 61 72 67 73 29 29 20 3a |ch(STR,&|args)) :|
|00001e50| 20 22 2a 2a 42 52 45 41 | 4b 2a 2a 22 29 3b 0d 20 | "**BREA|K**");. |
|00001e60| 20 20 20 61 72 67 20 3d | 20 28 61 72 67 73 20 3f | arg =| (args ?|
|00001e70| 20 78 6c 61 72 67 28 26 | 61 72 67 73 29 20 3a 20 | xlarg(&|args) : |
|00001e80| 73 5f 75 6e 62 6f 75 6e | 64 29 3b 0d 20 20 20 20 |s_unboun|d);. |
|00001e90| 78 6c 6c 61 73 74 61 72 | 67 28 61 72 67 73 29 3b |xllastar|g(args);|
|00001ea0| 0d 0d 20 20 20 20 2f 2a | 20 65 6e 74 65 72 20 74 |.. /*| enter t|
|00001eb0| 68 65 20 62 72 65 61 6b | 20 6c 6f 6f 70 20 2a 2f |he break| loop */|
|00001ec0| 0d 20 20 20 20 78 6c 62 | 72 65 61 6b 28 65 6d 73 |. xlb|reak(ems|
|00001ed0| 67 2c 61 72 67 29 3b 0d | 0d 20 20 20 20 2f 2a 20 |g,arg);.|. /* |
|00001ee0| 72 65 74 75 72 6e 20 6e | 69 6c 20 2a 2f 0d 20 20 |return n|il */. |
|00001ef0| 20 20 72 65 74 75 72 6e | 20 28 4e 49 4c 29 3b 0d | return| (NIL);.|
|00001f00| 7d 0d 0d 2f 2a 20 78 63 | 6c 65 61 6e 75 70 20 2d |}../* xc|leanup -|
|00001f10| 20 73 70 65 63 69 61 6c | 20 66 6f 72 6d 20 27 63 | special| form 'c|
|00001f20| 6c 65 61 6e 2d 75 70 27 | 20 2a 2f 0d 4e 4f 44 45 |lean-up'| */.NODE|
|00001f30| 20 2a 78 63 6c 65 61 6e | 75 70 28 61 72 67 73 29 | *xclean|up(args)|
|00001f40| 0d 20 20 4e 4f 44 45 20 | 2a 61 72 67 73 3b 0d 7b |. NODE |*args;.{|
|00001f50| 0d 20 20 20 20 78 6c 6c | 61 73 74 61 72 67 28 61 |. xll|astarg(a|
|00001f60| 72 67 73 29 3b 0d 20 20 | 20 20 78 6c 63 6c 65 61 |rgs);. | xlclea|
|00001f70| 6e 75 70 28 29 3b 0d 7d | 0d 0d 2f 2a 20 78 74 6f |nup();.}|../* xto|
|00001f80| 70 6c 65 76 65 6c 20 2d | 20 73 70 65 63 69 61 6c |plevel -| special|
|00001f90| 20 66 6f 72 6d 20 27 74 | 6f 70 2d 6c 65 76 65 6c | form 't|op-level|
|00001fa0| 27 20 2a 2f 0d 4e 4f 44 | 45 20 2a 78 74 6f 70 6c |' */.NOD|E *xtopl|
|00001fb0| 65 76 65 6c 28 61 72 67 | 73 29 0d 20 20 4e 4f 44 |evel(arg|s). NOD|
|00001fc0| 45 20 2a 61 72 67 73 3b | 0d 7b 0d 20 20 20 20 78 |E *args;|.{. x|
|00001fd0| 6c 6c 61 73 74 61 72 67 | 28 61 72 67 73 29 3b 0d |llastarg|(args);.|
|00001fe0| 20 20 20 20 78 6c 74 6f | 70 6c 65 76 65 6c 28 29 | xlto|plevel()|
|00001ff0| 3b 0d 7d 0d 0d 2f 2a 20 | 78 63 6f 6e 74 69 6e 75 |;.}../* |xcontinu|
|00002000| 65 20 2d 20 73 70 65 63 | 69 61 6c 20 66 6f 72 6d |e - spec|ial form|
|00002010| 20 27 63 6f 6e 74 69 6e | 75 65 27 20 2a 2f 0d 4e | 'contin|ue' */.N|
|00002020| 4f 44 45 20 2a 78 63 6f | 6e 74 69 6e 75 65 28 61 |ODE *xco|ntinue(a|
|00002030| 72 67 73 29 0d 20 20 4e | 4f 44 45 20 2a 61 72 67 |rgs). N|ODE *arg|
|00002040| 73 3b 0d 7b 0d 20 20 20 | 20 78 6c 6c 61 73 74 61 |s;.{. | xllasta|
|00002050| 72 67 28 61 72 67 73 29 | 3b 0d 20 20 20 20 78 6c |rg(args)|;. xl|
|00002060| 63 6f 6e 74 69 6e 75 65 | 28 29 3b 0d 7d 0d 0d 2f |continue|();.}../|
|00002070| 2a 20 78 65 76 61 6c 68 | 6f 6f 6b 20 2d 20 65 76 |* xevalh|ook - ev|
|00002080| 61 6c 20 68 6f 6f 6b 20 | 66 75 6e 63 74 69 6f 6e |al hook |function|
|00002090| 20 2a 2f 0d 4e 4f 44 45 | 20 2a 78 65 76 61 6c 68 | */.NODE| *xevalh|
|000020a0| 6f 6f 6b 28 61 72 67 73 | 29 0d 20 20 4e 4f 44 45 |ook(args|). NODE|
|000020b0| 20 2a 61 72 67 73 3b 0d | 7b 0d 20 20 20 20 4e 4f | *args;.|{. NO|
|000020c0| 44 45 20 2a 2a 2a 6f 6c | 64 73 74 6b 2c 2a 65 78 |DE ***ol|dstk,*ex|
|000020d0| 70 72 2c 2a 65 68 6f 6f | 6b 2c 2a 61 68 6f 6f 6b |pr,*ehoo|k,*ahook|
|000020e0| 2c 2a 6f 6c 64 65 6e 76 | 3b 0d 20 20 20 20 4e 4f |,*oldenv|;. NO|
|000020f0| 44 45 20 2a 6e 65 77 65 | 68 6f 6f 6b 2c 2a 6e 65 |DE *newe|hook,*ne|
|00002100| 77 61 68 6f 6f 6b 2c 2a | 6e 65 77 65 6e 76 2c 2a |wahook,*|newenv,*|
|00002110| 76 61 6c 3b 0d 0d 20 20 | 20 20 2f 2a 20 63 72 65 |val;.. | /* cre|
|00002120| 61 74 65 20 61 20 6e 65 | 77 20 73 74 61 63 6b 20 |ate a ne|w stack |
|00002130| 66 72 61 6d 65 20 2a 2f | 0d 20 20 20 20 6f 6c 64 |frame */|. old|
|00002140| 73 74 6b 20 3d 20 78 6c | 73 74 61 63 6b 3b 0d 20 |stk = xl|stack;. |
|00002150| 20 20 20 78 6c 73 74 6b | 63 68 65 63 6b 28 34 29 | xlstk|check(4)|
|00002160| 3b 0d 20 20 20 20 78 6c | 73 61 76 65 28 65 68 6f |;. xl|save(eho|
|00002170| 6f 6b 29 3b 0d 20 20 20 | 20 78 6c 73 61 76 65 28 |ok);. | xlsave(|
|00002180| 61 68 6f 6f 6b 29 3b 0d | 20 20 20 20 78 6c 73 61 |ahook);.| xlsa|
|00002190| 76 65 28 6f 6c 64 65 6e | 76 29 3b 0d 20 20 20 20 |ve(olden|v);. |
|000021a0| 78 6c 73 61 76 65 28 6e | 65 77 65 6e 76 29 3b 0d |xlsave(n|ewenv);.|
|000021b0| 0d 20 20 20 20 2f 2a 20 | 67 65 74 20 74 68 65 20 |. /* |get the |
|000021c0| 65 78 70 72 65 73 73 69 | 6f 6e 2c 20 74 68 65 20 |expressi|on, the |
|000021d0| 6e 65 77 20 68 6f 6f 6b | 20 66 75 6e 63 74 69 6f |new hook| functio|
|000021e0| 6e 73 20 61 6e 64 20 74 | 68 65 20 65 6e 76 69 72 |ns and t|he envir|
|000021f0| 6f 6e 6d 65 6e 74 20 2a | 2f 0d 20 20 20 20 65 78 |onment *|/. ex|
|00002200| 70 72 20 3d 20 78 6c 61 | 72 67 28 26 61 72 67 73 |pr = xla|rg(&args|
|00002210| 29 3b 0d 20 20 20 20 6e | 65 77 65 68 6f 6f 6b 20 |);. n|ewehook |
|00002220| 3d 20 78 6c 61 72 67 28 | 26 61 72 67 73 29 3b 0d |= xlarg(|&args);.|
|00002230| 20 20 20 20 6e 65 77 61 | 68 6f 6f 6b 20 3d 20 78 | newa|hook = x|
|00002240| 6c 61 72 67 28 26 61 72 | 67 73 29 3b 0d 20 20 20 |larg(&ar|gs);. |
|00002250| 20 6e 65 77 65 6e 76 20 | 3d 20 28 61 72 67 73 20 | newenv |= (args |
|00002260| 3f 20 78 6c 61 72 67 28 | 26 61 72 67 73 29 20 3a |? xlarg(|&args) :|
|00002270| 20 78 6c 65 6e 76 29 3b | 0d 20 20 20 20 78 6c 6c | xlenv);|. xll|
|00002280| 61 73 74 61 72 67 28 61 | 72 67 73 29 3b 0d 0d 20 |astarg(a|rgs);.. |
|00002290| 20 20 20 2f 2a 20 62 69 | 6e 64 20 2a 65 76 61 6c | /* bi|nd *eval|
|000022a0| 68 6f 6f 6b 2a 20 61 6e | 64 20 2a 61 70 70 6c 79 |hook* an|d *apply|
|000022b0| 68 6f 6f 6b 2a 20 74 6f | 20 74 68 65 20 68 6f 6f |hook* to| the hoo|
|000022c0| 6b 20 66 75 6e 63 74 69 | 6f 6e 73 20 2a 2f 0d 20 |k functi|ons */. |
|000022d0| 20 20 20 65 68 6f 6f 6b | 20 3d 20 67 65 74 76 61 | ehook| = getva|
|000022e0| 6c 75 65 28 73 5f 65 76 | 61 6c 68 6f 6f 6b 29 3b |lue(s_ev|alhook);|
|000022f0| 0d 20 20 20 20 73 65 74 | 76 61 6c 75 65 28 73 5f |. set|value(s_|
|00002300| 65 76 61 6c 68 6f 6f 6b | 2c 6e 65 77 65 68 6f 6f |evalhook|,newehoo|
|00002310| 6b 29 3b 0d 20 20 20 20 | 61 68 6f 6f 6b 20 3d 20 |k);. |ahook = |
|00002320| 67 65 74 76 61 6c 75 65 | 28 73 5f 61 70 70 6c 79 |getvalue|(s_apply|
|00002330| 68 6f 6f 6b 29 3b 0d 20 | 20 20 20 73 65 74 76 61 |hook);. | setva|
|00002340| 6c 75 65 28 73 5f 61 70 | 70 6c 79 68 6f 6f 6b 2c |lue(s_ap|plyhook,|
|00002350| 6e 65 77 61 68 6f 6f 6b | 29 3b 0d 20 20 20 20 6f |newahook|);. o|
|00002360| 6c 64 65 6e 76 20 3d 20 | 78 6c 65 6e 76 3b 0d 20 |ldenv = |xlenv;. |
|00002370| 20 20 20 78 6c 65 6e 76 | 20 3d 20 6e 65 77 65 6e | xlenv| = newen|
|00002380| 76 3b 0d 0d 20 20 20 20 | 2f 2a 20 65 76 61 6c 75 |v;.. |/* evalu|
|00002390| 61 74 65 20 74 68 65 20 | 65 78 70 72 65 73 73 69 |ate the |expressi|
|000023a0| 6f 6e 20 28 62 79 70 61 | 73 73 69 6e 67 20 2a 65 |on (bypa|ssing *e|
|000023b0| 76 61 6c 68 6f 6f 6b 2a | 29 20 2a 2f 0d 20 20 20 |valhook*|) */. |
|000023c0| 20 76 61 6c 20 3d 20 78 | 6c 78 65 76 61 6c 28 65 | val = x|lxeval(e|
|000023d0| 78 70 72 29 3b 0d 0d 20 | 20 20 20 2f 2a 20 75 6e |xpr);.. | /* un|
|000023e0| 62 69 6e 64 20 74 68 65 | 20 68 6f 6f 6b 20 76 61 |bind the| hook va|
|000023f0| 72 69 61 62 6c 65 73 20 | 2a 2f 0d 20 20 20 20 73 |riables |*/. s|
|00002400| 65 74 76 61 6c 75 65 28 | 73 5f 65 76 61 6c 68 6f |etvalue(|s_evalho|
|00002410| 6f 6b 2c 65 68 6f 6f 6b | 29 3b 0d 20 20 20 20 73 |ok,ehook|);. s|
|00002420| 65 74 76 61 6c 75 65 28 | 73 5f 61 70 70 6c 79 68 |etvalue(|s_applyh|
|00002430| 6f 6f 6b 2c 61 68 6f 6f | 6b 29 3b 0d 20 20 20 20 |ook,ahoo|k);. |
|00002440| 78 6c 65 6e 76 20 3d 20 | 6f 6c 64 65 6e 76 3b 0d |xlenv = |oldenv;.|
|00002450| 0d 20 20 20 20 2f 2a 20 | 72 65 73 74 6f 72 65 20 |. /* |restore |
|00002460| 74 68 65 20 70 72 65 76 | 69 6f 75 73 20 73 74 61 |the prev|ious sta|
|00002470| 63 6b 20 66 72 61 6d 65 | 20 2a 2f 0d 20 20 20 20 |ck frame| */. |
|00002480| 78 6c 73 74 61 63 6b 20 | 3d 20 6f 6c 64 73 74 6b |xlstack |= oldstk|
|00002490| 3b 0d 0d 20 20 20 20 2f | 2a 20 72 65 74 75 72 6e |;.. /|* return|
|000024a0| 20 74 68 65 20 72 65 73 | 75 6c 74 20 2a 2f 0d 20 | the res|ult */. |
|000024b0| 20 20 20 72 65 74 75 72 | 6e 20 28 76 61 6c 29 3b | retur|n (val);|
|000024c0| 0d 7d 0d 0d 00 00 00 00 | 00 00 00 00 00 00 00 00 |.}......|........|
|000024d0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000024e0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|000024f0| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002500| 00 00 01 00 00 00 01 16 | 00 00 00 16 00 00 00 46 |........|.......F|
|00002510| 0a 38 4e 75 59 4f 3f 3c | 00 11 a9 b8 20 5f 20 50 |.8NuYO?<|.... _ P|
|00002520| 4e 75 20 68 00 1c 20 50 | 49 e8 00 02 d6 6c 00 02 |Nu h.. P|I....l..|
|00002530| 08 78 6c 62 66 75 6e 2e | 63 00 02 00 00 00 54 45 |.xlbfun.|c.....TE|
|00002540| 58 54 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |XT......|........|
|00002550| 00 00 54 45 58 54 00 00 | 00 00 00 00 00 00 00 00 |..TEXT..|........|
|00002560| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002570| 00 00 9b 2f 58 f1 00 00 | 24 44 00 00 01 5c 4e 75 |.../X...|$D...\Nu|
|00002580| 20 68 00 1c a0 23 4e 75 | 3f 00 30 02 e2 48 48 41 | h...#Nu|?.0..HHA|
|00002590| b2 40 6f 08 48 41 52 41 | 30 1f 4e 75 48 41 60 f8 |.@o.HARA|0.NuHA`.|
|000025a0| 28 43 26 14 45 d4 22 4a | 61 00 fe 8e 20 4a 61 00 |(C&.E."J|a... Ja.|
|000025b0| fd ae 3f 02 48 42 34 3c | ff e8 38 00 67 04 48 42 |..?.HB4<|..8.g.HB|
|000025c0| 60 02 48 43 2f 0a 2f 02 | a8 a9 41 ec 00 08 20 94 |`.HC/./.|..A... .|
|000025d0| 21 6c 00 04 00 04 20 3c | ff 80 00 00 4a 44 67 02 |!l.... <|....JDg.|
|000025e0| 48 40 2f 08 2f 00 a8 a9 | 20 53 20 68 00 1c 20 50 |H@/./...| S h.. P|
|000025f0| 96 70 40 02 d7 72 40 00 | 34 1f 53 42 95 72 40 04 |.p@..r@.|4.SB.r@.|
|00002600| 00 00 00 0a 00 09 06 4d | 6f 6e 61 63 6f 12 00 00 |.......M|onaco...|
|00002610| 00 04 00 06 00 08 00 00 | 01 00 00 00 01 16 00 00 |........|........|
|00002620| 00 16 00 00 00 46 00 00 | cc 24 02 94 00 00 00 1c |.....F..|.$......|
|00002630| 00 46 00 01 45 46 4e 54 | 00 00 00 12 45 54 41 42 |.F..EFNT|....ETAB|
|00002640| 00 00 00 1e 03 eb ff ff | 00 00 00 00 00 01 97 d4 |........|........|
|00002650| 03 ec ff ff 00 00 00 0e | 00 01 97 c4 00 00 00 00 |........|........|
|00002660| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00002670| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
+--------+-------------------------+-------------------------+--------+--------+